Loop Pipelining and Optimization for Run Time Reconfiguration
نویسندگان
چکیده
Lack of automatic mapping techniques is a signi cant hurdle in obtaining high performance for general purpose computing on recongurable hardware. In this paper, we develop techniques for mapping loop computations from applications onto high performance pipelined con gurations. Loop statements with generalized directed acyclic graph dependencies are mapped onto multiple pipeline segments. Each pipeline segment is executed for a xed number of iterations before the hardware is recon gured at runtime to execute the next segment. The recon guration cost is amortized over the multiple iterations of the execution of the loop statements. This alleviates the bottleneck of high recon guration overheads in current architectures. The paper describes heuristic techniques to construct pipeline con gurations which have reduced total execution time including the runtime recon guration overheads. The performance bene ts which can be achieved using our approach are illustrated by mapping example application loop onto Virtex series FPGA from Xilinx.
منابع مشابه
Translation and Run - Time Validation of Optimized Code 1 , 2
The paper presents approaches to the validation of optimizing compilers. The emphasis is on aggressive and architecture-targeted optimizations which try to obtain the highest performance from modern architectures, in particular EPIC-like microprocessors. Rather than verify the compiler, the approach of translation validation performs a validation check after every run of the compiler, producing...
متن کاملEnabling Loop Parallelization with Decoupled Software Pipelining in LLVM: Final Report
Software pipelining is an optimization technique used to speed up the execution of loops. A compiler performing the optimization reorders instructions within a loop in order to minimize latencies and avoid wasting instruction cycles. The optimization parallels the out-of-order execution paradigm used by microprocessors, except that instruction reordering is done at the software level, i.e. by t...
متن کاملEnhanced Loop Flattening for Software Pipelining of Arbitrary Loop Nests
This paper introduces and evaluates enhanced loop flattening, a compiler framework for transforming an arbitrary set of nested and sequenced loops into a single loop with additional logic to implement the control flow of the original code. Loop flattening allows conventional software pipelining algorithms to effectively pipeline nested loops. Conventional software pipelining approaches are only...
متن کاملReconfiguration of distribution systems to improve reliability and reduce power losses using Imperialist Competitive Algorithm
Distribution systems can be operated in multiple configurations since they are possible combinations of radial and loop feeders. Each configuration leads to its own power losses and reliability level of supplying electric energy to customers. In order to obtain the optimal configuration of power networks, their reconfiguration is formulated as a complex optimization problem with different objec...
متن کاملA Dynamic Modulo Scheduling with Binary Translation: Loop optimization with software compatibility
In the past years, many works have demonstrated the applicability of Coarse-Grained Reconfigurable Array (CGRA) accelerators to optimize loops by using software pipelining approaches. They are proven to be effective in reducing the total execution time of multimedia and signal processing applications. However, the run-time reconfigurability of CGRAs is hampered overheads introduced by the neede...
متن کامل